#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n, k;
int msb(ll x) {
  int cnt = 0;
  while (x) {
    cnt++;
    x >>= 1;
  }
  return cnt;
}
int main() {
  int t;
  cin >> t;

  while (t--) {
    cin >> n >> k;
    n--;
    ll ans = 0;

    if (n) {
      int cnt = msb(k);
      // 在k条线缆全部用上之前可以传输的数量
      int has = 0;
      for (int i = 0; i < cnt; ++i) {
        n -= (1LL << i);
        ans++;
        if (n <= 0) break;
      }
      if (n > 0) {
        ans += n / k;
        if (n % k) ans++;
      }
    }
    cout << ans << endl;
  }
}
